# Clocked Synchronous Sequential Circuits

In sequential circuits, output values depend on both the input values and the state of the circuit. Output = f(Input, State)

Clocked synchronous sequential circuits are designed based on the *finite state* machine model, where the current state is stored in memory elements (flip-flops).

All flip-flops are triggered with the same clock signal (synchronized). Therefore, the machine can change its state only during the active transition of the clock signal.

A sequential circuit can be designed as either a Mealy or Moore model.

a) Mealy Model (George H. Mealy (1927-2010), computer scientist, USA) In this model, outputs (O) are determined by a function of current input values (I) and current state (S). O = G(I,S)



**Digital Circuits** 

# b) Moore Model

Edward Forrest Moore (1925-2003) Mathematician, computer scientist, USA In this model, the output depends only on the current state.

Input values determine only the next state.

And the state determines the output. O = G(S)



Most sequential circuits can be designed using either one of these models (Mealy or Moore).

Next States in Mealy and Moore models: In both models, next state St is determined by a function H, which is a combination of function F and characteristic equations of the flip-flops.  $S^+ = H(I,S)$ 

http://akademi.itu.edu.tr/en/buzluca/

Digital Circuits

# Analysis of clocked synchronous sequential circuits

Before we start to design sequential circuits, we will see how to analyze a given

Reminder: Implementation of a sequential circuit means implementation of the functions F (flip-flop excitation) and G (output). (See 8.1 and 8.2)

I: Input. S: Current State. S+: Next state. O: Output  $S^+ = \mathbf{H}(I,S)$ , Mealy: O = G(I,S)Moore: O = G(S)

Analyzing a synchronous circuit means determining the behavior of the circuit (i.e., answering the question "What does the circuit do?"), which is given by the functions

# The analysis of a synchronous circuit consists of five steps:

- 1. Determine the expressions of the function F (inputs of flip-flops).
- 2. Use F and characteristic functions of the flip-flops to find the expression of H.
- 3. Construct the state table that specifies the next state of the circuit for every possible combination of input and current state.
- 4. Determine the expressions of the output function G.
- 5. Determine the output values using G, and construct the state/output table. (Optional) To see the behavior of the circuit better, draw the state diagram (also called a state graph), which shows all state transitions and outputs of the machine graphically. http://akademi.itu.edu.tr/en/buzluca/ http://www.buzluca.info

2011 - 2022 Feza BUZLUCA

Digital Circuits

# Determination of next states (function H):

The F function of a clocked sequential circuit determines the input values of the flip-flops (flip-flop excitation).

These input values, along with the current state of the flip-flop, determine the next state of the flip-flop (i.e., the output of the flip-flop after the transition of the clock signal) (Slides 8.1 and 8.2).

$$S^+ = \mathbf{H}(I,S)$$

Function H is a combination of function F and characteristic equations of the flipflops.

The functional behavior of a latch or flip-flop can be described by a characteristic equation that specifies the flip-flop's next state as a function of its inputs and current state.

Characteristic equations for the flip-flops:

 $Q(t+1) = S + \overline{R} \cdot Q(t)$  (SR = 0) S-R FF:

 $Q(t+1) = J \cdot \overline{Q(t)} + \overline{K} \cdot Q(t)$ J-K FF:

Q(t+1) = DD FF

T FF  $Q(t+1) = T \oplus Q(t)$ 







- 4. Determine the expression for the output function O = G(S,l).  $Z = Q_1 {}^{\bullet}Q_0 {}^{\bullet}X$  (Mealy model because output depends both on input and state)
- 5. Construct the state/output table



This table presents the behavior of the finite state machine.

This behavior can also be presented graphically by a state diagram.



# Reading the table:

When the machine is in state A: if it receives a "1" at the input, the output becomes 0; after the transition of the clock signal, the machine goes to state B.

Verbal expression of the behavior of the circuit: We assume that A is the initial state. Only if the number of 1s received at the input is a multiple of 4, the output is 1. Otherwise, the output is 0.

http://akademi.itu.edu.tr/en/buzluca/

2011 – 2022 Feza BUZLUCA 8.



# Example: Analysis of a clocked synchronous circuit with J-K flip-flops

Unlike the previous example, when determining the expressions for the next states ( $Q_i^{\star}$ ) here, we will use the characteristic function for the JK flip-flop.

Reminder:  $Q^+ = J \cdot Q' + K' \cdot Q$  (characteristic function for the JK flip-flop)





http://akademi.itu.edu.tr/en/buzluca/

nttp://www.buzluca.info

2011 - 2022 Feza BUZLUCA 8.8

### Digital Circuits

1. Determine the F function that drives the inputs of the flip-flops:

$$J_{0} = X \cdot Y'$$

$$K_{0} = X \cdot Y' + Y \cdot Q_{1}$$

$$J_{1} = X \cdot Q_{0} + Y$$

$$K_{1} = Y \cdot Q_{0}' + X \cdot Y' \cdot Q_{0}$$

2. Determine the next state  $S^+=\{Q_0(t^+), Q_1(t^+)\}$  expressions.  $S^+=H(S,I)$ 

$$\begin{array}{l} Q_0^+ = J_0 \raisebox{-1pt}{\ensuremath{\bullet}} Q_0^- + K_0^- \raisebox{-1pt}{\ensuremath{\bullet}} Q_0^- & \text{(J-K FF characteristic function)} \\ Q_0^+ = X \raisebox{-1pt}{\ensuremath{\bullet}} Y \raisebox{-1pt}{\ensuremath{\bullet}} Q_0^- + (X \raisebox{-1pt}{\ensuremath{\bullet}} Y + Y \raisebox{-1pt}{\ensuremath{\bullet}} Q_0^- + Y \raisebox{-1pt}{\ensuremath{\bullet}} Q_0^- + X^- \raisebox{-1pt}{\ensuremath{\bullet}} Y \raisebox{-1pt}{\ensuremath{\bullet}} Q_0^- + X^- \raisebox{-1pt}{\ensuremath{\bullet}} Y \raisebox{-1pt}{\ensuremath{\bullet}} Q_0^- + Y \raisebox{-1pt}{\ensuremath{\bullet}} Q_0^$$

$$Q_0^+ = X \cdot Y' \cdot Q_0' + (X \cdot Y' + Y \cdot Q_1)' \cdot Q_0$$

$$Q_0^+ = X \cdot Y' \cdot Q_0' + X' \cdot Y' \cdot Q_0 + X' \cdot Q_1' \cdot Q_0 + Y \cdot Q_1' \cdot Q_0$$

$$Q_0^+ = X \cdot Y' \cdot Q_0' + X' \cdot Y' \cdot Q_0 + Y \cdot Q_1' \cdot Q_0 \qquad \text{(minimization)}$$

$$Q_1^+ = J_1 \cdot Q_1' + K_1' \cdot Q_1$$
 (J-K FF characteristic function)

$$Q_1^+ = (X \cdot Q_0 + Y) \cdot Q_1^+ + (Y \cdot Q_0^+ + X \cdot Y^+ \cdot Q_0^-)^+ \cdot Q_1^-$$

$$\begin{array}{l} Q_{1}{}^{+}=J_{1}{}^{\bullet}Q_{1}{}^{'}+K_{1}{}^{'}{}^{\bullet}Q_{1} & \text{(J-K FF characteristic function)} \\ Q_{1}{}^{+}=(X{}^{\bullet}Q_{0}+Y){}^{\bullet}Q_{1}{}^{'}+(Y{}^{\bullet}Q_{0}{}^{'}+X{}^{\bullet}Y{}^{'}{}^{\bullet}Q_{0}{}^{'}{}^{\bullet}Q_{1} \\ Q_{1}{}^{+}=X{}^{\bullet}Q_{1}{}^{'}{}^{\bullet}Q_{0}+Y{}^{\bullet}Q_{1}{}^{'}+X{}^{'}{}^{\bullet}Y{}^{'}{}^{\bullet}Q_{1}+Y{}^{'}{}^{\bullet}Q_{1}{}^{\bullet}Q_{0}{}^{'}+X{}^{'}{}^{\bullet}Q_{1}{}^{\bullet}Q_{0}+Y{}^{\bullet}Q_{1}{}^{\bullet}Q_{0} \\ Q_{1}{}^{+}=X{}^{\bullet}Q_{1}{}^{'}{}^{\bullet}Q_{0}+Y{}^{\bullet}Q_{1}{}^{'}+Y{}^{\bullet}Q_{0}+X{}^{'}{}^{\bullet}Q_{1}{}^{\bullet}Q_{0}+Y{}^{\prime}{}^{\bullet}Q_{0}{}^{'} & \text{(minimization)} \end{array}$$

$$Q_1^+ = X \cdot Q_1^+ \cdot Q_0^- + Y \cdot Q_1^+ + Y \cdot Q_0^- + X^+ \cdot Q_1^- \cdot Q_0^- + Y^+ \cdot Q_1^- \cdot Q_0^+$$
 (minimization)

3. Determine the expression of the output function G.

$$Z = X \cdot Q_1 \cdot Q_0 + Y \cdot Q_1' \cdot Q_0'$$

http://akademi.itu.edu.tr/en/buzluca/ http://www.buzluca.info

2011 - 2022 Feza BUZLUCA

### Digital Circuits

## State/Output Table:

 $Q_1^+ Q_0^+, Z$ 

|          | XY                            |                               |                                                                                                                                                 |                                                                                                                                               |  |  |
|----------|-------------------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| $Q_1Q_0$ | 00                            | 01                            | 10                                                                                                                                              | 11                                                                                                                                            |  |  |
| 00       | 00,0                          | 10,1                          | 01,0                                                                                                                                            | 10,1                                                                                                                                          |  |  |
| 01       | 01,0                          | 11,0                          | 10,0                                                                                                                                            | 11,0                                                                                                                                          |  |  |
| 10       | 10,0                          | 00,0                          | 11,0                                                                                                                                            | 00,0                                                                                                                                          |  |  |
| 11       | 11,0                          | 10,0                          | 00,1                                                                                                                                            | 10,1                                                                                                                                          |  |  |
|          | <b>Q₁Q₀</b><br>00<br>01<br>10 | 00 00,0<br>01 01,0<br>10 10,0 | Q1Q0         00         01           00         00,0         10,1           01         01,0         11,0           10         10,0         00,0 | Q1Q0         00         01         10           00         00,0         10,1         01,0           01         01,0         11,0         10,0 |  |  |

|   | XY  |     |     |     |  |  |
|---|-----|-----|-----|-----|--|--|
| S | 00  | 01  | 10  | 11  |  |  |
| Α | A,0 | C,1 | B,0 | C,1 |  |  |
| В | B,0 | D,0 | C,0 | D,0 |  |  |
| С | C,0 | A,0 | D,0 | A,0 |  |  |
| D | D,0 | C,0 | A,1 | C,1 |  |  |

### State Transition Diagram:



2011 - 2022 Feza BUZLUCA 8.10

Digital Circuits

Analysis of a clocked synchronous sequential circuit designed according to the Moore model:

Remember that in Moore model, the output depends only on the current state.

In the circuit below, output Z depends only on state variables  $(Q_1, Q_0)$ .

Input

Analysis of a clocked synchronous sequential circuit designed according to the Moore output depends only on the current state.

In the circuit below, output Z depends only on state variables  $(Q_1, Q_0)$ .

http://akademi.itu.edu.tr/en/buzluca/ http://www.buzluca.info

Q<sub>1</sub> Q<sub>1</sub>

2011 – 2022 Feza BUZLUCA 8.11

current state

### Digital Circuits

CLK-

The analysis of circuits designed according to the Moore model is very similar to that of circuits designed according to the Mealy model.

They differ only in the construction and interpretation of the state/output table.

1. Determine the expression for the F function that drives the flip-flops:

$$D_0 = Q_0 \cdot X' + Q_0' \cdot X$$

$$D_1 = Q_1 \cdot X' + Q_1' \cdot Q_0 \cdot X + Q_1 \cdot Q_0' \cdot X$$

2. Determine the next state  $S^+=\{Q_0(t^+), Q_1(t^+)\}$  expressions.  $S^+=H(S,I)$ 

$$Q_0^+ = D_0$$

$$Q_1^+ = D_1$$

$$Q_0^+ = Q_0 \cdot X' + Q_0' \cdot X$$

$$Q_1^+ = Q_1 \cdot X' + Q_1' \cdot Q_0 \cdot X + Q_1 \cdot Q_0' \cdot X$$

3. Construct the transition table and the state table.

| Q <sub>1</sub> + C | $Q_0^{\dagger}$ X | 0  | 1  |                            | S <sup>+</sup> X | 0 | 1 |
|--------------------|-------------------|----|----|----------------------------|------------------|---|---|
| Ī                  | 00                | 00 | 01 | For simplicity, letters of | Α                | Α | В |
|                    | 01                | 01 | 10 | the alphabet are           | В                | В | С |
|                    | 10                | 10 | 11 | assigned to state codes.   | C                | С | D |
|                    | 11                | 11 | 00 | 255.g.,52 15 51415 65465.  | D                | D | Α |

S: Current state S+: Next state  $Q_1$  and  $Q_0$ : State variables



- 4. Determine the expression of the output function G  $Z = Q_1 \cdot Q_0$  (Moore model; output depends only on state variables.)
- 5. Construct the state/output table.



Since the output depends only on the present state in the Moore model, there is only a single output column (only one output value is written in each row), independent of the input.

Each row corresponds to a state.

# Reading the table and diagram:

When the machine is in state A: if it receives a "1" at the input after the transition of the clock signal,

- the machine goes to state B, and then
- the output becomes 0.

In the state diagram of a circuit in the Moore model, the output value for each state is written in the state circle because the output is a function of only the present state.



http://akademi.itu.edu.tr/en/buzluca/

2011 - 2022 Feza BUZLUCA 8.13

### Digital Circuits

# Interpretation of Outputs in Mealy and Moore Models

If you check the output of a digital circuit at a certain moment, you will always read a logical 0 or 1 (except high impedance outputs).

However, this value may not be valid due to some reasons. For example, due to internal delays, the circuit might not have finished its job, yet.

Therefore, it is important when to read (sample) the output.

In clocked synchronous sequential circuits, outputs are sampled (read) at different times depending on the model (Mealy or Moore).

# Mealy Model:

Since the output depends also on the input, if the input changes, the output changes at the same time (actually, after the propagation delay).

A circuit designed using the Mealy model operates as follows:

- 1. Input values (I) are applied.
- 2. Output values are obtained as a function of the input and current state. O=G(S,I)
- 3. The active edge of the clock signal (for example, rising edge (0 to 1 transition)) arrives at the flip-flops.
- 4. The machine goes to the next state. The next state is a function of the input and current state.  $S^+=H(S,I)$



### **Digital Circuits**

### Moore Model:

In the Moore model, since the output is the function of the state only, change in the input cannot affect the output immediately.

The effect of changes in input can be seen on the output just after the change in the state.

A circuit designed using the Moore model operates as follows:

- Input values (I) are applied.
- The active edge of the clock signal (for example, rising edge (0 to 1 transition)) arrives at the flip-flops.
- The machine goes to the next state. The next state is a function of the input and current state.  $S^{+}=H(S,I)$
- The output value is determined as a function of the new state. O=G(S)

In the Moore model, the output which results from application of a given input does not appear until after the clock pulse.

Therefore, the output sequence is displaced in time with respect to the input sequence.





